@charset "UTF-8";

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
html {
    line-height: 1.15;
    -webkit-text-size-adjust: 100%
}

body {
    margin: 0
}

main {
    display: block
}

h1 {
    font-size: 2em;
    margin: .67em 0
}

hr {
    box-sizing: content-box;
    height: 0;
    overflow: visible
}

pre {
    font-family: monospace, monospace;
    font-size: 1em
}

a {
    background-color: transparent
}

abbr[title] {
    border-bottom: none;
    text-decoration: underline;
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted
}

b,
strong {
    font-weight: bolder
}

code,
kbd,
samp {
    font-family: monospace, monospace;
    font-size: 1em
}

.card.\--full p,
small {
    font-size: 80%
}

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

img {
    border-style: none
}

button,
input,
optgroup,
select,
textarea {
    font-family: inherit;
    font-size: 100%;
    line-height: 1.15;
    margin: 0
}

button,
input {
    overflow: visible
}

button,
select {
    text-transform: none
}

[type=button],
[type=reset],
[type=submit],
button {
    -webkit-appearance: button
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
    border-style: none;
    padding: 0
}

[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring,
button:-moz-focusring {
    outline: 1px dotted ButtonText
}

fieldset {
    padding: .35em .75em .625em
}

legend {
    box-sizing: border-box;
    color: inherit;
    display: table;
    max-width: 100%;
    padding: 0;
    white-space: normal
}

progress {
    vertical-align: baseline
}

textarea {
    overflow: auto
}

[type=checkbox],
[type=radio] {
    box-sizing: border-box;
    padding: 0
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

details {
    display: block
}

summary {
    display: list-item
}

[hidden],
template {
    display: none
}

@font-face {
    font-family: Roboto Condensed;
    src: url(../../../static/fonts/RobotoMono-Light.ttf) format("woff2");
    font-weight: 400;
    font-display: swap
}

@font-face {
    font-family: Eksell Display;
    src: url(../../../static/fonts/Gloock-Regular.ttf) format("woff2");
    font-weight: 1 999;
    font-display: swap
}

@font-face {
    font-family: Roboto Mono;
    src: url(../../../static/fonts/RobotoMono-Light.ttf) format("woff2");
    font-weight: 1 999;
    font-display: swap
}

@font-face {
    font-family: songti;
    src: url(../../../static/fonts/Songti.ttc) ;
    font-weight: 800;
    font-display: swap
}


html {
    font-family: Roboto Mono, monospace;
    font-variation-settings: "wght" 300;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 16px;
    line-height: 32px;
    letter-spacing: .03em;
    font-weight: 300;
}

@media screen and (min-width:1024px) {
    html {
        font-size: 18px
    }
}

@media screen and (min-width:1280px) {
    html {
        font-size: 19px
    }
}

.workshop blockquote,
h1,
h2,
h3,
h4,
h5,
h6,
p {
    margin: 0
}

.workshop blockquote+*,
h1+*,
h2+*,
h3+*,
h4+*,
h5+*,
h6+*,
p+* {
    margin-top: 40px
}

a {
    color: inherit
}

a.nd {
    text-decoration: none;
    transition: -webkit-text-decoration .15s ease-in;
    transition: text-decoration .15s ease-in;
    transition: text-decoration .15s ease-in, -webkit-text-decoration .15s ease-in
}

a.nd:hover {
    text-decoration: underline;
    text-decoration-thickness: from-font
}

.mega-title {
    font-family: Eksell Display, serif;
    font-variation-settings: "wght" 80;
    font-size: 18vw;
    line-height:1;
    padding-bottom: .15em
}

@media screen and (min-width:768px) {
    .mega-title {
        font-size: 16vw
    }
}

@media screen and (min-width:1024px) {
    .mega-title {
        font-size: 15vw
    }
}

@media screen and (min-width:1440px) {
    .mega-title {
        font-size: 17vw
    }
}

@media screen and (min-width:1600px) {
    .mega-title {
        font-size: 253px;
        max-width: 1560px
    }
}

main .mega-title {
    background-image: linear-gradient(134deg, #3515a1, #000000);
    color: transparent;
    -webkit-background-clip: text;
    background-clip: text
}

@media screen and (min-width:1280px) {
    main .mega-title {
        background-attachment: fixed
    }
}

.title {
    font-family: Eksell Display, serif;
    font-variation-settings: "wght" 80;
    font-size: clamp(64px, 8vw, 80px);
    line-height: 1.1;
    padding-bottom: .15em
}

@media screen and (min-width:1440px) {
    .title {
        font-size: 104px;
        line-height: 112px
    }
}

.condensed,
.h5,
.h6,
blockquote cite,
h5,
h6 {
    font-family: Roboto Mono;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: .3em
}

.h1,
h1 {
    font-family: Eksell Display, serif;
    font-variation-settings: "wght" 80;
    letter-spacing: 0;
    font-size: clamp(56px, 10vw, 104px);
    line-height: 1
}

@media screen and (min-width:1600px) {

    .h1,
    h1 {
        font-size: 128px
    }
}

.h2,
h2 {
    font-family: Eksell Display, serif;
    font-variation-settings: "wght" 90;
    font-size: clamp(40px, 5.5vw, 64px);
    line-height: 1.125
}

.h2,
.h3,
h2,
h3 {
    letter-spacing: 0
}

.h3,
h3 {
    font-family: Eksell Display, serif;
    font-variation-settings: "wght" 90;
    font-size: clamp(40px, 5.5vw, 48px);
    line-height: 1.0833333333
}

.h4,
.workshop blockquote,
h4 {
    font-family: Eksell Display, serif;
    font-variation-settings: "wght" 90;
    font-size: clamp(24px, 5.5vw, 32px);
    line-height: 1.25;
    letter-spacing: 0;
    text-transform: none
}

.h5,
blockquote cite,
h5 {
    font-size: 14px;
    line-height: 24px
}

@media screen and (min-width:1280px) {

    .h5,
    blockquote cite,
    h5 {
        font-size: 16px
    }
}

.h6,
h6 {
    font-size: 14px;
    line-height: 24px
}

.process_title {
    font-family: Eksell Display, serif;
    font-variation-settings: "wght" 80;
    letter-spacing: 0;
    font-size: clamp(64px, 10vw, 88px);
    line-height: clamp(64px, 10vw, 88px)
}

.num {
    font-family: Roboto Mono;
    font-variation-settings: "wght" 400;
    font-size: 24px;
    line-height: 24px;
    text-transform: uppercase;
    letter-spacing: 0
}

.flag__content p,
.flag__content p *,
.lead,
.lead *,
strong {
    font-family: Roboto Mono, monospace;
    font-variation-settings: "wght" 300;
    letter-spacing: .03em;
    font-weight: 300;
}

.flag__content p,
.lead {
    font-size: 18px;
    line-height: 32px
}

@media screen and (min-width:768px) {

    .flag__content p,
    .lead {
        font-size: 20px;
        line-height: 40px
    }
}

@media screen and (min-width:1160px) {

    .flag__content p,
    .lead {
        font-size: 24px;
        line-height: 40px
    }
}

.flag__content p strong,
.lead strong {
    font-variation-settings: "wght" 600
}

.card.\--full p,
.links .link__inner p,
.small,
small {
    font-family: Roboto Mono, monospace;
    font-variation-settings: "wght" 300;
    font-size: 14px;
    line-height: 24px;
    letter-spacing: .03em;
    text-transform: none
}

.cards ul,
.flag__content ul,
ul.small-list {
    font-family: Roboto Mono, monospace;
    letter-spacing: .03em;
    font-size: 14px;
    line-height: 1.7142857143;
    font-variation-settings: "wght" 350
}

.cards ul li,
.flag__content ul li,
ul.small-list li {
    margin-bottom: 8px;
    display: block
}

.cards ul li:before,
.flag__content ul li:before,
ul.small-list li:before {
    content: "—";
    font-size: .5em;
    padding-right: 12px;
    position: relative;
    top: -2px;
    font-variation-settings: "wght" 500
}

.cards ul li:last-of-type,
.flag__content ul li:last-of-type,
ul.small-list li:last-of-type {
    margin-bottom: 0
}

.btn {
    font-family: Eksell Display, serif;
    font-weight: 300;
    font-size: 18px;
    line-height: 20px;
    letter-spacing: 0;
    display: flex;
    align-items: baseline;
    width: 100%;
    padding: 13px 108px 13px 14px;
    border: 1px solid;
    justify-content: flex-start;
    text-decoration: none;
    position: relative;
    overflow: hidden;
    transition: color .3s cubic-bezier(.15, .85, .45, 1), background-color .3s cubic-bezier(.15, .85, .45, 1), border-color .3s cubic-bezier(.15, .85, .45, 1)
}

@media (pointer:fine) {
    .btn:hover {
        color: #fff;
        border: 1px solid #2F1F65;
        background: #2F1F65
    }
}

.btn:active,
.btn:focus {
    color: #fff;
    background: #2F1F65;
    border: 1px solid #00020f
}

@media screen and (min-width:480px) {
    .btn {
        width: auto
    }
}

@media screen and (min-width:768px) {
    .btn {
        font-size: 21px;
        line-height: 22px;
        padding: 20px 120px 20px 24px
    }
}

.btn:before {
    content: "";
    height: 1px;
    background: currentColor;
    display: block;
    width: 64px;
    margin-left: 48px;
    flex-shrink: 0;
    position: absolute;
    top: 47%;
    right: 24px
}

@media screen and (min-width:768px) {
    .btn:before {
        width: 80px;
        top: 50%;
        margin-left: 64px
    }
}

.btn:after {
    content: "";
    display: block;
    position: absolute;
    right: 26px;
    top: 50%;
    border-color: transparent currentcolor currentcolor transparent;
    border-style: solid;
    border-width: 1px;
    transform: rotate(-45deg);
    width: 11px;
    height: 11px;
    margin-top: -7px
}

@media screen and (min-width:768px) {
    .btn:after {
        margin-top: -6px
    }
}

blockquote {
    font-family: Eksell Display, serif;
    font-variation-settings: "wght" 100;
    font-size: 24px;
    line-height: 32px;
    margin: 0;
    padding: 0
}

@media screen and (min-width:768px) {
    blockquote {
        font-size: 28px;
        line-height: 40px
    }
}

@media screen and (min-width:1024px) {
    blockquote {
        font-size: 32px
    }
}

blockquote cite {
    display: block;
    margin-top: 24px;
    font-style: normal
}

.tag {
    display: inline-block;
    padding: 6px 12px;
    border: 1px solid;
    margin: 0 16px 8px 0;
    font-size: 10px;
    line-height: 1;
    white-space: pre;
    letter-spacing: .02em;
    text-transform: capitalize;
    font-variation-settings: "wght" 400
}

sub,
sup {
    font-size: .375em
}

sup {
    top: -1.5em
}

ul {
    list-style-type: none;
    padding: 0;
    margin: 0
}

ul li {
    display: flex
}

.credits p {
    margin-top: 16px
}

.credits h5+p {
    margin-top: 48px
}

.dash {
    position: relative;
    display: inline-block;
    height: 1em;
    width: 40px;
    margin: 0 16px 0 12px
}

.dash:after {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    height: 1px;
    width: 100%;
    background-color: currentColor;
    transform: translateY(-50%)
}

code {
    font-family: Roboto Mono, monospace;
    background-color: rgba(254, 230, 57, .2)
}

code,
strong {
    font-variation-settings: "wght" 400
}

.price {
    font-variation-settings: "wght" 600;
    text-transform: uppercase;
    letter-spacing: .3em;
    font-size: 16px;
    font-variation-settings: "wght" 700;
    display: inline-flex;
    padding: 0 12px 2px 16px;
    background-color: #00020f;
    color: #F5F3FF
}

.block-type-text a,
.credits a {
    transition: background-color .15s ease
}

.block-type-text a:focus,
.block-type-text a:hover,
.credits a:focus,
.credits a:hover {
    background-color: rgba(254, 230, 57, .2)
}

* {
    box-sizing: border-box
}

html {
    scroll-behavior: smooth
}

body {
    color: #00020f;
    background-color: #F5F3FF
}

.hidden {
    clip: rect(0 0 0 0);
    -webkit-clip-path: inset(50%);
    clip-path: inset(50%);
    height: 1px;
    overflow: hidden;
    position: absolute;
    white-space: nowrap;
    width: 1px
}

.overlaybg {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    pointer-events: none
}

.overlaybg:after,
.overlaybg:before,
.overlaybg_line,
.overlaybg_line_d {
    position: absolute;
    top: 0;
    height: 100%;
    width: 1px;
    background: rgba(0, 0, 0, .05);
    transform: translateX(-50%)
}

.overlaybg:before {
    content: "";
    left: 25%
}

@media screen and (min-width:1024px) {
    .overlaybg:before {
        left: 20%
    }
}

.overlaybg_line {
    left: 50%
}

@media screen and (min-width:1024px) {
    .overlaybg_line {
        left: 40%
    }
}

.overlaybg_line_d {
    display: none
}

@media screen and (min-width:1024px) {
    .overlaybg_line_d {
        display: block;
        left: 60%
    }
}

.overlaybg:after {
    content: "";
    left: 75%
}

@media screen and (min-width:1024px) {
    .overlaybg:after {
        left: 80%
    }
}

@media screen and (min-width:1024px) {
    .overlaybg {
        width: calc(100% - 72px);
        left: 72px
    }
}

img,
video {
    max-width: 100%;
    display: block;
    height: auto
}

footer a {
    text-decoration: none;
    transition: -webkit-text-decoration .15s ease-in;
    transition: text-decoration .15s ease-in;
    transition: text-decoration .15s ease-in, -webkit-text-decoration .15s ease-in
}

@media (pointer:fine) {
    footer a:hover {
        text-decoration: underline;
        text-decoration-thickness: from-font
    }
}

footer a:active,
footer a:focus {
    text-decoration: underline;
    text-decoration-thickness: from-font
}

.social,
.social a {
    display: flex
}

.social a {
    align-items: end
}

.social a+a {
    margin-left: 14px
}

.arrow-horizontal {
    display: block;
    height: 24px;
    max-width: 64px;
    width: 100%;
    position: relative
}

.arrow-horizontal:before {
    height: 1px;
    background: currentColor;
    width: 100%;
    flex-shrink: 0;
    left: 0
}

.arrow-horizontal:after,
.arrow-horizontal:before {
    content: "";
    display: block;
    position: absolute;
    top: 50%
}

.arrow-horizontal:after {
    right: 2px;
    border-color: transparent currentcolor currentcolor transparent;
    border-style: solid;
    border-width: 1px;
    transform: rotate(-45deg);
    width: 11px;
    height: 11px;
    margin-top: -6px
}

.line {
    display: inline-block;
    height: 1px;
    width: 40px;
    margin-left: 16px;
    position: relative;
    background-color: currentColor
}

html.home {
    overflow: hidden
}

html.home.no-js,
html.home.splash_seen {
    overflow: initial
}

body,
html {
    height: 100%;
    width: 100%
}

main {
    padding-top: 72px;
    opacity: 1
}

@media screen and (min-width:768px) {
    main {
        padding-top: 0
    }
}

main.--end-yellow .block-type-cta,
main .block-type-news,
main>.block-type-header,
main>.block-type-workshop+.block-type-promo {
    position: relative
}

main.--end-yellow .block-type-cta:before,
main .block-type-news:before,
main>.block-type-header:before,
main>.block-type-workshop+.block-type-promo:before {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    display: block;
    height: 1px;
    background: rgba(0, 0, 0, .2);
    content: ""
}

@media screen and (min-width:768px) {

    main.--end-yellow .block-type-cta:before,
    main .block-type-news:before,
    main>.block-type-header:before,
    main>.block-type-workshop+.block-type-promo:before {
        left: 72px
    }
}

main>.block.--end-yellow:last-child {
    position: relative
}

main>.block.--end-yellow:last-child:after {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    display: block;
    height: 1px;
    background: rgba(0, 0, 0, .2);
    content: ""
}

@media screen and (min-width:768px) {
    main>.block.--end-yellow:last-child:after {
        left: 72px
    }
}

main .block.--has-bg+.block-type-news:before {
    display: none
}

main .page_related:before {
    width: auto;
    margin-left: -16px;
    margin-right: -16px
}

@media screen and (min-width:1024px) {
    main .page_related:before {
        margin-left: -80px;
        margin-right: -120px;
        left: 0
    }
}

main>.block-type-header:first-child {
    padding-top: 0;
    padding-bottom: 0
}

main>.block-type-header:first-child:before {
    display: none
}

main>.block-type-work+.block-type-clients {
    padding-top: 0
}

.block {
    padding: 80px 24px
}

@media screen and (min-width:480px) {
    .block {
        padding: 80px 40px
    }
}

@media screen and (min-width:768px) {
    .block {
        padding: 120px 64px 120px 72px
    }
}

@media screen and (min-width:1024px) {
    .block {
        padding: 120px 72px
    }
}

@media screen and (min-width:1280px) {
    .block {
        padding-right: 80px;
        padding-left: 72px
    }
}

@media screen and (min-width:1280px) and (min-height:720px) {
    .block {
        padding-top: 160px;
        padding-bottom: 160px
    }
}

@media screen and (min-width:1024px) {
    .block.block-type-banner {
        padding-bottom: 0 !important
    }
}

@media screen and (min-width:480px) {
    .block.bg-solid-blue {
        margin-left: 40px;
        padding-left: 0
    }
}

@media screen and (min-width:768px) {
    .block.bg-solid-blue {
        margin-left: 72px;
        padding-left: 0
    }
}

@media screen and (min-width:1024px) {
    .block.bg-solid-blue {
        padding-left: 0
    }
}

@media screen and (min-width:1280px) {
    .block.bg-solid-blue {
        padding-left: 0
    }
}

@media screen and (min-width:1280px) {

    .block.article_page_header,
    .block.basic_page_header,
    .block.basic_page_header+.block,
    .block.block-type-news {
        padding-top: 120px
    }
}

.block.article_page_header+.block {
    padding-top: 0
}

.block.basic_page_header {
    position: relative
}

.block.basic_page_header:before {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    display: block;
    height: 1px;
    background: rgba(0, 0, 0, .2);
    content: ""
}

@media screen and (min-width:768px) {
    .block.basic_page_header:before {
        left: 72px
    }
}

@media screen and (min-width:768px) {
    .block:not(.block-type-cta)[class^=bg-solid-] {
        margin-left: 72px;
        padding-left: 0
    }
}

.block[class^=bg-solid-]+.block:before {
    display: none
}

.block_button {
    padding-top: 40px
}

@media screen and (min-width:480px) {

    .block-type-button p,
    .block_button {
        display: flex
    }
}

.block.\--no-bp {
    padding-bottom: 0
}

@media screen and (min-width:1024px) {
    .block.\--no-bp {
        padding-bottom: 0
    }
}

.block_inner {
    position: relative;
    z-index: 2;
    max-width: 1400px
}

@media screen and (min-width:768px) {
    .block_inner {
        padding: 0 0 0 64px
    }
}

@media screen and (min-width:1024px) {
    .block_inner {
        padding: 0 0 0 72px
    }
}

@media screen and (min-width:1280px) {
    .block_inner {
        padding: 0 0 0 80px
    }
}

@media screen and (min-width:1600px) {
    .block_inner {
        padding: 0 0 0 120px
    }
}

main>.block:first-child {
    padding-bottom: 64px
}

@media screen and (min-width:1024px) {
    main>.block:first-child {
        padding-bottom: 80px
    }
}

.color_page>.block:first-of-type,
.product_page>.block:first-of-type {
    padding-bottom: 0
}

@media screen and (min-width:1280px) {

    .color_page>.block:first-of-type,
    .product_page>.block:first-of-type {
        padding-top: 120px
    }
}

.color_page>.block:nth-of-type(2),
.product_page>.block:nth-of-type(2) {
    padding-top: 0
}

.color_page>.block:nth-of-type(2) .color_page_row:first-of-type,
.product_page>.block:nth-of-type(2) .color_page_row:first-of-type {
    margin-top: 0
}

@media screen and (min-width:1024px) {
    .df {
        display: flex
    }
}

.df.\--split {
    justify-content: space-between
}

.df-middle {
    align-self: center
}

@media screen and (min-width:480px) {
    .df-xs {
        display: flex
    }
}

.block-type-work-cards blockquote {
    max-width: 480px;
    margin-top: 64px
}

@media screen and (min-width:1024px) {
    .block-type-work-cards blockquote {
        margin-top: 80px;
        max-width: 50%
    }
}

@media screen and (min-width:1024px) {
    .btn-quote-wrap {
        display: flex;
        flex-direction: row;
        justify-content: space-between;
        align-items: flex-start
    }

    .btn-quote-wrap .block-type-cards-button {
        margin-right: 80px;
        align-self: flex-start
    }
}

.btn-quote-wrap .block_button {
    padding-top: 0
}

.btn-quote-wrap blockquote {
    max-width: 480px;
    margin-top: 64px
}

@media screen and (min-width:1024px) {
    .btn-quote-wrap blockquote {
        margin-top: 0;
        max-width: 50%
    }
}

@media screen and (min-width:1024px) {
    .home .btn-quote-wrap blockquote {
        margin-top: 80px
    }
}

.figures {
    display: flex;
    margin: 0 -16px
}

@media screen and (min-width:1024px) {
    .figures {
        margin: 0 -20px
    }
}

.figures figure {
    margin: 0;
    padding: 0 16px
}

@media screen and (min-width:1024px) {
    .figures figure {
        padding: 0 20px
    }
}

.figures figure figcaption {
    margin-top: 16px
}

.home .block-type-cards {
    padding-top: 0
}

@-webkit-keyframes spin {
    0% {
        transform: rotate(0deg)
    }

    to {
        transform: rotate(-1turn)
    }
}

@keyframes spin {
    0% {
        transform: rotate(0deg)
    }

    to {
        transform: rotate(-1turn)
    }
}

@-webkit-keyframes fadeIn {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@keyframes fadeIn {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@-webkit-keyframes fadeOut {
    0% {
        opacity: 1
    }

    to {
        opacity: 0
    }
}

@keyframes fadeOut {
    0% {
        opacity: 1
    }

    to {
        opacity: 0
    }
}

@-webkit-keyframes fadeInUp {
    0% {
        opacity: 0;
        transform: translateY(12.5vh)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

@keyframes fadeInUp {
    0% {
        opacity: 0;
        transform: translateY(12.5vh)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

@-webkit-keyframes fadeInSplash {
    0% {
        transform: translateY(12.5vh)
    }

    to {
        transform: translateY(0)
    }
}

@keyframes fadeInSplash {
    0% {
        transform: translateY(12.5vh)
    }

    to {
        transform: translateY(0)
    }
}

@-webkit-keyframes slideInMain {
    0% {
        transform: translateY(100vh)
    }

    to {
        transform: translateY(0)
    }
}

@keyframes slideInMain {
    0% {
        transform: translateY(100vh)
    }

    to {
        transform: translateY(0)
    }
}

.flow>*+* {
    -webkit-margin-before: var(--flow-space, 1em);
    margin-block-start: var(--flow-space, 1em)
}

.bg {
    --start: transparent;
    --end: transparent
}

.bg-solid-black {
    background: #00020f
}

.bg.\--start-black {
    --start: #00020f
}

.bg.\--end-black {
    --end: #00020f
}

.bg-solid-cream {
    background: #F5F3FF
}

.bg.\--start-cream {
    --start: #F5F3FF
}

.bg.\--end-cream {
    --end: #F5F3FF
}

.bg-solid-blue {
    background: #2F1F65
}

.bg.\--start-blue {
    --start: #2F1F65
}

.bg.\--end-blue {
    --end: #2F1F65
}

.bg-solid-yellow {
    background: #ff2d3b
}

.bg.\--start-yellow {
    --start: #ff2d3b
}

.bg.\--end-yellow {
    --end: #ff2d3b
}

.bg-gradient {
    /* background: linear-gradient(180deg, var(--start) 50%, var(--end)) */
}

.bg-solid-black,
.bg-solid-blue {
    color: #fff;
    -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
    position: relative;
    z-index: 13;
    pointer-events: none
}

.bg-solid-black .block_inner,
.bg-solid-black header,
.bg-solid-blue .block_inner,
.bg-solid-blue header {
    pointer-events: auto
}

.bg-solid-black header,
.bg-solid-blue header {
    border-right: 1px solid hsla(0, 0%, 100%, .2)
}

body.colour .bg-solid-black,
body.colour .bg-solid-blue {
    z-index: 10
}

.bg-solid-black .bg-solid-cream,
.bg-solid-black .bg-solid-yellow,
.bg-solid-black .bg.\--end-cream,
.bg-solid-black .bg.\--end-yellow,
.bg-solid-blue .bg-solid-cream,
.bg-solid-blue .bg-solid-yellow,
.bg-solid-blue .bg.\--end-cream,
.bg-solid-blue .bg.\--end-yellow {
    color: #00020f
}

.bg-solid-yellow+.bg-solid-yellow,
.bg.\--end-yellow+.bg-solid-yellow {
    position: relative
}

.bg-solid-yellow+.bg-solid-yellow:before,
.bg.\--end-yellow+.bg-solid-yellow:before {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    display: block;
    height: 1px;
    background: rgba(0, 0, 0, .2);
    content: ""
}

@media screen and (min-width:1024px) {

    .bg-solid-yellow+.bg-solid-yellow:before,
    .bg.\--end-yellow+.bg-solid-yellow:before {
        left: 72px
    }
}

header {
    position: fixed;
    top: 0;
    left: 0;
    display: flex;
    width: 100%;
    height: 72px;
    padding: 20px 24px;
    justify-content: space-between;
    align-items: center;
    z-index: 15;
    transition: background-color .6s cubic-bezier(.15, .85, .45, 1) 0s;
    transition-delay: 1.2s;
    background-color: #F5F3FF;
    border-bottom: 1px solid rgba(0, 0, 0, .2)
}

@media screen and (min-width:768px) {
    header {
        align-items: unset;
        height: 100%;
        width: 72px;
        padding: 48px 20px;
        flex-direction: column;
        border-right: 1px solid rgba(0, 0, 0, .2);
        border-bottom: none;
        background-color: transparent
    }
}

header .logo img {
    /* width: 100% */
}

@media screen and (min-width:768px) {
    header .logo {
        transform: rotate(-90deg);
        height: 28px;
        width: 201.74px;
        transform-origin: 16px
    }
}

.nav_trigger {
    position: relative;
    top: 1px
}

@media screen and (min-width:768px) {
    .nav_trigger {
        top: -5px
    }
}

#menu-toggle {
    width: 32px;
    height: 32px;
    position: relative;
    cursor: pointer
}

#menu-toggle span {
    display: block;
    background: #000;
    transition: .25s ease-in-out
}

#menu-toggle #hamburger {
    position: absolute;
    height: 100%;
    width: 100%
}

#menu-toggle #hamburger span {
    height: 3px;
    position: relative;
    top: 0;
    left: 0;
    margin: 5px 0
}

#menu-toggle #hamburger span:first-child {
    width: 32px;
    transition-duration: .25s;
    transition-delay: .625s
}

#menu-toggle #hamburger span:nth-child(2) {
    width: 24px;
    transition-duration: .1875s;
    transition-delay: .75s
}

#menu-toggle #hamburger span:nth-child(3) {
    transition-duration: .21875s;
    transition-delay: .875s;
    width: 28px
}

#menu-toggle #cross {
    position: absolute;
    height: 32px;
    width: 32px;
    top: 1px;
    transform: rotate(45deg)
}

#menu-toggle #cross span {
    width: 3px
}

#menu-toggle #cross span:first-child {
    height: 0%;
    position: absolute;
    top: 2px;
    left: 13px;
    transition-delay: 0s
}

#menu-toggle #cross span:nth-child(2) {
    width: 0;
    position: absolute;
    left: 2px;
    top: 13px;
    transition-delay: .125s
}

body.nav_active header {
    border-color: #F5F3FF
}

@media screen and (min-width:768px) {
    body.nav_active header {
        background: #F5F3FF;
        border: none;
        transition-delay: 0s;
        transition-duration: 0s
    }
}

body.nav_active #menu-toggle #hamburger {
    background: transparent
}

body.nav_active #menu-toggle #hamburger span {
    width: 0
}

body.nav_active #menu-toggle #hamburger span:first-child {
    transition-delay: 0s
}

body.nav_active #menu-toggle #hamburger span:nth-child(2) {
    transition-delay: .125s
}

body.nav_active #menu-toggle #hamburger span:nth-child(3) {
    transition-delay: .25s
}

body.nav_active #menu-toggle #cross span:first-child {
    height: 25px;
    width: 3px;
    transition-delay: .75s
}

body.nav_active #menu-toggle #cross span:nth-child(2) {
    width: 25px;
    height: 3px;
    transition-delay: .875s
}

.nav_container_main__footer,
.nav_container_side {
    opacity: 0;
    transition: opacity .6s ease
}

.nav_container {
    position: fixed;
    height: 100vh;
    overflow-y: auto;
    width: 100%;
    top: 0;
    bottom: 0;
    right: 0;
    transform: translateX(-100%);
    background-color:#2F1F65;
    color: #fff;
    z-index: 14;
    padding-top: 72px;
    display: flex;
    flex-direction: column
}

@media screen and (min-width:768px) {
    .nav_container {
        height: 100%;
        display: flex;
        padding-top: 0;
        flex-direction: row;
        right: auto;
        left: 72px;
        margin-left: -72px;
        padding-left: 72px
    }
}

.nav_container_main {
    padding: 64px 24px 24px;
    height: 100%
}

@media screen and (min-width:480px) {
    .nav_container_main {
        padding: 48px 40px
    }
}

@media screen and (min-width:768px) {
    .nav_container_main {
        padding: 64px;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        flex-grow: 1
    }
}

@media screen and (min-width:1024px) {
    .nav_container_main {
        padding: 80px
    }
}

.nav_container_main__large {
    color: #F5F3FF;
    font-size: clamp(56px,14vw,96px);
    line-height: clamp(56px, 19vw, 96px);
    -webkit-animation: fadeOut;
    animation: fadeOut;
    -webkit-animation-duration: .2s;
    animation-duration: .2s;
    -webkit-animation-timing-function: ease;
    animation-timing-function: ease;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both
}

@media screen and (min-width:768px) {
    .nav_container_main__large {
        font-size: clamp(64px, 8vw, 144px);
        line-height: clamp(64px, 10vw, 144px);
        max-width: 65vw
    }
}

@media screen and (min-width:1280px) {
    .nav_container_main__large {
        font-size: clamp(64px, 9vw, 144px);
        line-height: clamp(64px, 12vw, 144px)
    }
}

@media screen and (min-width:1440px) {
    .nav_container_main__large {
        font-size: clamp(64px, 9vw, 204px);
        line-height: clamp(64px, 11vw, 204px)
    }
}

.nav_container_main__large a {
    text-decoration: none;
    color: #fff;
    transition: color .15s ease-in
}

@media (pointer:fine) {
    .nav_container_main__large a:hover {
        color: #D53741
    }
}

.nav_container_main__large a:active,
.nav_container_main__large a:focus {
    color: #D53741
}

.nav_container_main__footer {
    margin-top: 40px
}

@media screen and (min-width:768px) {
    .nav_container_main__footer {
        margin-top: 80px
    }
}

@media screen and (min-width:1024px) {
    .nav_container_main__footer {
        display: flex
    }
}

.nav_container_main__footer span {
    display: block
}

.nav_container_main__footer span+span {
    margin-top: 24px
}

@media screen and (min-width:1024px) {
    .nav_container_main__footer span+span {
        margin-top: 0;
        margin-left: 80px
    }
}

.nav_container_side {
    border-top: 1px solid hsla(0, 0%, 100%, .2);
    display: flex;
    min-height: 64px
}

@media screen and (min-width:768px) {
    .nav_container_side {
        width: 72px;
        min-height: unset;
        white-space: pre
    }
}

.nav_container_side_link {
    padding: 12px 24px;
    display: flex;
    align-items: center;
    width: 100%;
    text-decoration: none;
    transition: background-color .15s ease-in
}

@media (pointer:fine) {
    .nav_container_side_link:hover {
        background-color: hsla(0, 0%, 100%, .05)
    }

    .nav_container_side_link:hover span {
        color: #00020f
    }
}

.nav_container_side_link:active span,
.nav_container_side_link:focus span {
    background-color: hsla(0, 0%, 100%, .05)
}

.nav_container_side_link:active span span,
.nav_container_side_link:focus span span {
    color: #00020f
}

.nav_container_side_link span {
    transition: color .15s ease-in;
    font-family: Eksell Display, serif;
    font-variation-settings: "wght" 100;
    font-size: 24px;
    padding-left: 24px;
    text-transform: none;
    letter-spacing: 0
}

@media screen and (min-width:768px) {
    .nav_container_side_link span {
        padding-top: 24px;
        padding-left: 0
    }
}

@media screen and (min-width:768px) {
    .nav_container_side_link span sup {
        top: 0;
        right: -.75em
    }
}

@media screen and (min-width:768px) {
    .nav_container_side_link {
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        padding: 80px 24px
    }
}

@media screen and (min-width:768px) {
    .nav_container_side {
        height: 100%;
        border-top: 0;
        border-left: 1px solid hsla(0, 0%, 100%, .2)
    }
}

.nav_loaded .nav_container {
    transition: transform .6s cubic-bezier(.15, .85, .45, 1) .4s
}

.nav_active {
    overflow: hidden
}

.nav_active .nav_container {
    transform: translateX(0);
    transition: transform .6s cubic-bezier(.15, .85, .45, 1) 0s
}

.nav_active .nav_container .nav_container_main__large {
    -webkit-animation: fadeIn;
    animation: fadeIn;
    -webkit-animation-duration: 1.2s;
    animation-duration: 1.2s;
    -webkit-animation-timing-function: ease;
    animation-timing-function: ease;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
    -webkit-animation-delay: .2s;
    animation-delay: .2s
}

.nav_active .nav_container .nav_container_main__footer,
.nav_active .nav_container .nav_container_side {
    opacity: 1;
    transition: opacity 1.2s ease;
    transition-delay: .4s
}

.archive .simple-header {
    padding: 80px 16px
}

@media screen and (min-width:1024px) {
    .archive .simple-header {
        padding: 120px 80px 80px
    }
}

.archive__filter {
    margin-bottom: 48px
}

@media screen and (min-width:1024px) {
    .archive__filter {
        margin-bottom: 80px
    }
}

@media screen and (min-width:1024px) {
    .archive__filter__inner {
        border: 1px solid rgba(0, 0, 0, .2);
        display: flex
    }
}

.archive__button {
    margin-top: 64px
}

@media screen and (min-width:480px) {
    .archive__button {
        display: flex
    }
}

@media screen and (min-width:1024px) {
    .archive__button {
        margin-top: 80px
    }
}

.archive__pagination {
    margin-top: 80px
}

@media screen and (min-width:1024px) {
    .archive__pagination {
        margin-top: 120px
    }
}

.archive__pagination a {
    text-decoration: none
}

.archive__pagination a[aria-current=page] {
    text-decoration: line-through;
    text-decoration-thickness: from-font
}

.filter {
    position: relative
}

@media screen and (min-width:1024px) {
    .filter {
        width: 50%;
        padding: 24px 0
    }
}

@media screen and (min-width:1024px) {
    .filter:first-child {
        padding-left: 48px;
        padding-right: 40px
    }
}

@media screen and (min-width:1280px) {
    .filter:first-child {
        padding-left: 64px
    }
}

@media screen and (min-width:1024px) {
    .filter:nth-child(2) {
        padding-left: 40px;
        padding-right: 48px
    }
}

@media screen and (min-width:1280px) {
    .filter:nth-child(2) {
        padding-right: 64px
    }
}

.filter_heading {
    padding: 0 0 16px
}

@media screen and (min-width:1024px) {
    .filter_heading {
        position: absolute;
        top: 0;
        padding: 0 24px;
        background: #F5F3FF;
        transform: translateY(-50%) translateX(-24px)
    }
}

.filter_tags {
    text-transform: capitalize
}

@media screen and (min-width:1024px) {
    .filter_tags {
        line-height: 1
    }
}

.filter_tags span {
    display: none
}

@media screen and (min-width:1024px) {
    .filter_tags span {
        display: inline
    }
}

@media screen and (min-width:1024px) {
    .filter_tags .tag {
        font-size: 12px;
        font-variation-settings: "wght" 300
    }
}

@media (pointer:fine) {
    .filter_tags .tag:hover {
        text-decoration: underline
    }
}

.filter_tags .tag:active,
.filter_tags .tag:focus {
    text-decoration: underline
}

.filter_tags a {
    text-decoration: none;
    display: inline-block;
    margin: 0 16px 16px 0;
    line-height: 1
}

@media screen and (min-width:1024px) {
    .filter_tags a {
        padding: 0;
        border: 0;
        margin: 0
    }
}

.filter_tags a.current {
    background: #00020f;
    color: #fff
}

@media screen and (min-width:1024px) {
    .filter_tags a.current {
        background: inherit;
        color: inherit;
        text-decoration: underline;
        text-decoration-thickness: from-font
    }
}

.filter+.filter {
    margin-top: 8px
}

@media screen and (min-width:1024px) {
    .filter+.filter {
        margin-top: 0
    }
}

@media screen and (min-width:480px) {
    .work_archive {
        display: flex;
        flex-wrap: wrap
    }
}

.work_card {
    position: relative;
    display: block;
    background: #2F1F65;
    color: #fff;
    text-decoration: none
}

.work_card:nth-child(2n) {
    background: #fee639;
    color: #00020f
}

@media screen and (min-width:480px) {
    .work_card {
        width: 50%
    }
}

@media screen and (min-width:1024px) {
    .work_card {
        width: 33.333%
    }

    .work_card:nth-child(odd) {
        background: #2F1F65;
        color: #fff
    }

    .work_card:nth-child(2n) {
        background: #fee639;
        color: #00020f
    }
}

.work_card__image {
    position: relative;
    z-index: 1;
    transition: opacity .3s cubic-bezier(.15, .85, .45, 1)
}

.work_card__image img {
    width: 100%
}

.work_card__text {
    padding: 24px;
    display: flex;
    flex-direction: column-reverse
}

@media screen and (min-width:1024px) {
    .work_card__text {
        padding: 40px
    }
}

@media (pointer:fine) {
    .work_card__text {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%
    }
}

.work_card__tags {
    margin-top: 0;
    margin-bottom: 24px;
    height: 100%
}

@media screen and (min-width:1024px) {
    .work_card__tags {
        margin-bottom: 12px
    }
}

@media (pointer:fine) {
    .work_card:hover .work_card__image {
        opacity: 0
    }
}

.work_card__title {
    display: flex;
    align-items: flex-end;
    justify-content: space-between
}

@media screen and (min-width:480px) {
    .work_card--archive {
        width: 50%
    }

    .work_card--archive:nth-child(4n+3) {
        background: #fee639;
        color: #00020f
    }

    .work_card--archive:nth-child(4n),
    .work_card--archive:nth-child(4n+1) {
        background: #2F1F65;
        color: #fff
    }
}

@media screen and (min-width:1024px) {
    .work_card--archive {
        width: 33.333%
    }

    .work_card--archive:nth-child(odd) {
        background: #2F1F65;
        color: #fff
    }

    .work_card--archive:nth-child(2n) {
        background: #fee639;
        color: #00020f
    }
}

@media screen and (min-width:1440px) {
    .work_card--archive {
        width: 25%
    }
}

h2+.work_archive {
    margin-top: 80px
}

@media screen and (min-width:1024px) {
    .block-type-footer {
        padding-top: 80px;
        padding-bottom: 80px
    }
}

.block-type-footer .contact {
    font-size: 16px
}

.block-type-footer .contact p {
    margin-bottom: 48px
}

.block-type-footer .js-carbon a,
.block-type-footer .social {
    margin: 24px 0 80px
}

@media screen and (min-width:1024px) {

    .block-type-footer .js-carbon a,
    .block-type-footer .social {
        margin: 0
    }
}

@media screen and (min-width:1024px) {

    .block-type-footer .df .links .link__inner p,
    .block-type-footer .df .small,
    .links .link__inner .block-type-footer .df p {
        text-align: right;
        display: flex;
        flex-direction: column;
        justify-content: space-between
    }
}

.block-type-footer .js-carbon a {
    padding-left: 16px;
    display: inline-block;
    position: relative
}

.block-type-footer .js-carbon a:before {
    content: "";
    height: 1px;
    background: currentColor;
    display: block;
    width: 8px;
    position: absolute;
    left: 0;
    top: 50%;
    margin-top: 0;
    opacity: .5
}

.block-type-footer .js-carbon a:after {
    content: "";
    display: block;
    position: absolute;
    left: 2px;
    top: 50%;
    border-color: transparent currentcolor currentcolor transparent;
    border-style: solid;
    border-width: 1px;
    transform: rotate(-45deg);
    width: 3px;
    height: 3px;
    margin-top: -2px;
    opacity: .5
}

.page_line {
    height: 1px;
    background: rgba(0, 0, 0, .2);
    margin: 0 -16px 80px
}

@media screen and (min-width:1024px) {
    .page_line {
        margin: 0 -160px 120px -80px
    }
}

.page_header {
    position: relative
}

@media screen and (min-width:1024px) {
    .page_header {
        display: grid;
        grid-template-columns: 1fr 1fr;
        align-items: flex-end;
        grid-gap: 72px
    }

    .page_header_intro {
        margin-bottom: 6px
    }
}

@media screen and (min-width:1280px) {
    .page_header {
        grid-gap: 80px
    }
}

.page_header_heading {
    display: flex;
    flex-direction: column-reverse;
    margin-bottom: 24px
}

@media screen and (min-width:1024px) {
    .page_header_heading {
        margin-bottom: 0
    }
}

.page_header_heading .h5,
.page_header_heading blockquote cite,
blockquote .page_header_heading cite {
    margin: 0 0 48px
}

@media screen and (min-width:1024px) {

    .page_header_heading .h5,
    .page_header_heading blockquote cite,
    blockquote .page_header_heading cite {
        margin: 0 0 64px
    }
}

.page_header_heading a {
    text-decoration: none
}

.page_header_heading a:hover {
    text-decoration: underline;
    text-decoration-thickness: from-font
}

@media screen and (min-width:1024px) {
    .page_header .tag {
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        margin: 0;
        padding: 12px 6px
    }
}

.page_image {
    margin-bottom: 80px;
    position: relative
}

@media screen and (min-width:1024px) {
    .page_image {
        margin-bottom: 120px
    }
}

.page_image img {
    width: 100%
}

@media screen and (min-width:1280px) {
    .page_image img {
        padding-right: 88px
    }
}

@media screen and (min-width:1280px) {
    .page_image:before {
        width: 1px;
        height: 64px;
        background: currentColor;
        margin-left: 48px;
        flex-shrink: 0;
        top: 0;
        right: 12px
    }

    .page_image:after,
    .page_image:before {
        content: "";
        display: block;
        position: absolute
    }

    .page_image:after {
        right: 6px;
        top: 64px;
        border-color: transparent transparent currentcolor currentcolor;
        border-style: solid;
        border-width: 1px;
        transform: rotate(-45deg);
        width: 11px;
        height: 11px;
        margin-top: -15px
    }
}

.page_content>.block:first-of-type {
    margin-top: 0 !important
}

.page_content__inner>.block:first-child {
    margin-top: 0
}

@media screen and (min-width:1024px) {
    .page_content--share {
        display: flex;
        justify-content: space-between
    }
}

.page_content .block {
    padding: 0;
    margin: 40px 0
}

.page_content .block:not(.block-type-figure) {
    max-width: 680px
}

@media screen and (min-width:1024px) {
    .page_content .block:not(.block-type-figure) {
        margin-right: 64px
    }
}

.page_content .block.block-type-h1 {
    margin: 64px 0 48px
}

@media screen and (min-width:1024px) {
    .page_content .block.block-type-h1 {
        margin: 80px 0 64px
    }
}

.page_content .block.block-type-intro {
    margin-bottom: 48px
}

@media screen and (min-width:768px) {
    .page_content .block.block-type-intro {
        margin-bottom: 64px
    }
}

.page_content .block.block-type-button {
    margin: 64px 0
}

@media screen and (min-width:1024px) {
    .page_content .block.block-type-button {
        margin: 80px 0
    }
}

.page_content .block.block-type-blockquote,
.page_content .block.block-type-credits,
.page_content .block.block-type-figure {
    margin: 64px 0
}

@media screen and (min-width:1024px) {

    .page_content .block.block-type-blockquote,
    .page_content .block.block-type-credits,
    .page_content .block.block-type-figure {
        margin: 80px 0
    }
}

@media screen and (min-width:1280px) {

    .page_content .block.block-type-blockquote,
    .page_content .block.block-type-credits,
    .page_content .block.block-type-figure {
        margin: 120px 0
    }
}

.page_content .block.block-type-text>p:last-of-type,
.page_content .block:last-of-type,
.page_content__inner>.block:last-of-type {
    margin-bottom: 0
}

.page_related .page_related_heading {
    padding-bottom: 16px
}

.page_related .related {
    margin-top: 64px
}

.page_related .tag {
    margin-top: 24px;
    margin-bottom: 0
}

.page_related_button {
    margin-top: 80px
}

@media screen and (min-width:480px) {
    .page_related_button {
        display: flex
    }
}

@media screen and (min-width:1024px) {
    .page .article_page_header .page_header {
        display: flex;
        justify-content: space-between;
        align-items: flex-start
    }
}

@media screen and (min-width:1024px) {
    .page .article_page_header .page_header_inner {
        display: grid;
        grid-gap: 80px;
        grid-template-columns: 1fr 1fr;
        align-items: end
    }
}

@media screen and (min-width:1024px) {
    .page .article_page_header .page_header_heading {
        padding-right: 64px
    }
}

@media screen and (min-width:1024px) {
    .page.\--article .article_page_header .page_header {
        grid-gap: 0
    }
}

.flag__content .page.\--work .article_page_header p,
.page.\--work .article_page_header .flag__content p,
.page.\--work .article_page_header .lead {
    margin-bottom: 24px
}

@media screen and (min-width:1024px) {

    .flag__content .page.\--work .article_page_header p,
    .page.\--work .article_page_header .flag__content p,
    .page.\--work .article_page_header .lead {
        margin-bottom: 0
    }
}

@media screen and (min-width:640px) {
    .news_archive {
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-gap: 24px
    }
}

@media screen and (min-width:1160px) {
    .news_archive {
        grid-template-columns: 1fr 1fr 1fr;
        grid-gap: 40px
    }
}

.news_article {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    border: 1px solid rgba(0, 0, 0, .2);
    text-decoration: none;
    padding: 16px;
    margin-bottom: 24px
}

.news_article:last-of-type {
    margin-bottom: 0
}

@media screen and (min-width:480px) {
    .news_article {
        margin-bottom: 40px
    }
}

@media screen and (min-width:640px) {
    .news_article {
        padding: 24px;
        margin-bottom: 0
    }
}

@media screen and (min-width:1280px) {
    .news_article {
        padding: 40px
    }
}

.news_article .h4 {
    margin: 40px 0 0
}

@media (pointer:fine) {
    .news_article .h4 {
        transition: transform .15s ease-out 0s
    }

    .news_article .arrow-horizontal {
        opacity: 0;
        transform: translateY(40px);
        transition: transform .15s ease-out 0s, opacity .15s ease-out 0s;
        margin-top: 0
    }

    .news_article:hover {
        background-color: #00020f;
        color: #fff
    }

    .news_article:hover .h4 {
        transform: translateY(-24px)
    }

    .news_article:hover .arrow-horizontal {
        opacity: 1;
        transform: translateY(0)
    }
}

@media screen and (min-width:480px) {
    .news .page_related_button {
        display: flex
    }
}

.video_player,
.video_player__poster {
    position: relative
}

.video_player__poster__img {
    width: 100%
}

.video_player__poster__title {
    color: #fff;
    position: absolute;
    bottom: 23%;
    left: 0;
    width: 100%;
    text-align: center;
    margin: 0;
    line-height: 1
}

@media screen and (min-width:768px) {
    .video_player__poster__title {
        bottom: 56px;
        left: 64px;
        width: auto;
        text-align: left
    }
}

.video_player__play {
    position: absolute;
    bottom: 25%;
    left: 50%;
    transform: translate(-50%, -50%);
    cursor: pointer;
    width: 64px;
    height: 64px;
    background-color: hsla(0, 0%, 100%, .2);
    border-radius: 50%;
    box-shadow: 0 4px 24px rgba(0, 0, 0, .1);
    border: 1px solid rgba(0, 0, 0, .5);
    transition: background-color .15s cubic-bezier(.15, .85, .45, 1);
    display: flex;
    justify-content: center;
    align-items: center
}

@media screen and (min-width:768px) {
    .video_player__play {
        bottom: unset;
        top: 50%;
        width: 80px;
        height: 80px
    }
}

@media screen and (min-width:1024px) {
    .video_player__play {
        width: 120px;
        height: 120px
    }
}

.video_player__play__triangle {
    position: relative;
    display: block;
    width: 21px;
    height: 24px;
    left: 4px
}

@media screen and (min-width:1024px) {
    .video_player__play__triangle {
        width: 31px;
        height: 36px
    }
}

.video_player__play__triangle__base,
.video_player__play__triangle__hover {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    transition: opacity .15s ease-in
}

.video_player__play__triangle__base {
    opacity: .5
}

.video_player__play__triangle__hover {
    opacity: 0
}

.video_player__play .visually-hidden:not(:focus):not(:active) {
    clip: rect(0 0 0 0);
    -webkit-clip-path: inset(100%);
    clip-path: inset(100%);
    height: 1px;
    overflow: hidden;
    position: absolute;
    white-space: nowrap;
    width: 1px
}

.video_player__play:hover {
    background-color: hsla(0, 0%, 100%, .5)
}

.video_player__play:hover .video_player__play__triangle__hover {
    opacity: 1
}

.video_player__play:hover .video_player__play__triangle__base {
    opacity: 0
}

.video_player__video {
    clip: rect(0 0 0 0);
    -webkit-clip-path: inset(50%);
    clip-path: inset(50%);
    height: 1px;
    overflow: hidden;
    position: absolute;
    white-space: nowrap;
    width: 1px
}

.video_player.active .video_player__poster {
    display: none
}

.video_player.active .video_player__video {
    position: relative;
    height: auto;
    width: auto;
    clip: auto;
    -webkit-clip-path: none;
    clip-path: none
}

.client_grid {
    margin-top: 80px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-gap: 20px;
    justify-content: center
}

@media screen and (min-width:600px) {
    .client_grid {
        grid-template-columns: repeat(4, 1fr);
        grid-gap: 40px
    }
}

@media screen and (min-width:1100px) {
    .client_grid {
        grid-template-columns: repeat(6, 1fr)
    }
}

.client_grid img {
    width: 100%
}

.basic-card {
    --flow-space: 24px;
    border: 1px solid
}

.basic-card__body {
    padding: 0 40px 40px
}

.basic-card h3 {
    padding: 40px;
    border-bottom: 1px solid
}

.basic-card p {
    text-wrap: balance;
    max-width: 60ch
}

.basic-card p+form {
    -webkit-margin-before: 40px;
    margin-block-start: 40px
}

.basic-card .btn {
    --flow-space: 40px
}

.colour>header {
    background: #F5F3FF;
    border-right-width: 0
}

.colour>footer {
    position: relative
}

.colour>footer:before {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    display: block;
    width: 1px;
    background: rgba(0, 0, 0, .2);
    content: ""
}

@media screen and (min-width:768px) {
    .colour>footer:before {
        left: 72px
    }
}

@media screen and (min-width:1280px) {
    .color_page_header {
        display: flex
    }

    .color_page_header .color_page_content {
        width: 680px;
        align-items: flex-end
    }

    .color_page_header img {
        width: 100%
    }
}

@media screen and (min-width:1440px) {
    .color_page_header .color_page_content {
        width: 840px
    }
}

.color_page_heading {
    display: flex;
    flex-direction: column-reverse;
    justify-content: flex-end;
    width: 100%
}

.color_page_heading h1 {
    margin-top: 32px
}

@media screen and (min-width:1024px) {
    .color_page_heading h1 {
        margin-top: 64px
    }
}

.color_page_heading .h5,
.color_page_heading blockquote cite,
blockquote .color_page_heading cite {
    margin-top: 0
}

.color_page_heading span,
.color_page_intro span,
.color_page_row_content span {
    font-family: Roboto Condensed, monospace;
    font-variation-settings: "wght" 300;
    font-weight: 300;
    font-size: 16px;
    line-height: 1;
    letter-spacing: .03em;
    position: relative
}

.color_page_heading span {
    top: -4.8vw
}

@media screen and (min-width:1024px) {
    .color_page_heading span {
        top: -56px
    }
}

.color_page_intro span {
    top: -1.5vw
}

@media screen and (min-width:1024px) {
    .color_page_intro span {
        top: -24px
    }
}

.color_page_image,
.color_page_intro,
.color_page_row_content {
    max-width: 680px;
    margin-top: 24px
}

@media screen and (min-width:1280px) {

    .color_page_image,
    .color_page_intro,
    .color_page_row_content {
        width: 680px;
        max-width: unset;
        margin-top: 0;
        flex-shrink: 0
    }
}

@media screen and (min-width:1440px) {

    .color_page_image .color_page_content,
    .color_page_intro .color_page_content,
    .color_page_row_content .color_page_content {
        width: 840px
    }
}

@media screen and (min-width:1280px) {

    .color_page_intro,
    .color_page_row_content {
        margin-top: 0;
        margin-left: 80px
    }
}

.color_page_intro {
    justify-self: flex-end;
    margin-top: 64px;
    margin-bottom: 16px
}

@media screen and (min-width:1024px) {
    .color_page_intro {
        margin-top: 80px;
        margin-bottom: 40px
    }
}

.color_page_content {
    display: flex;
    flex-direction: column
}

.color_page_content .h3 {
    line-height: clamp(48px, 6vw, 64px)
}

.color_page_row {
    margin-top: 64px
}

@media screen and (min-width:1024px) {
    .color_page_row {
        margin-top: 80px
    }
}

@media screen and (min-width:1280px) {
    .color_page_row {
        display: flex;
        width: 100%
    }
}

.color_page_row_heading {
    width: 100%;
    margin-bottom: 24px
}

.color_page_block {
    margin-top: 64px
}

@media screen and (min-width:1024px) {
    .color_page_block {
        width: 100%;
        margin-top: 80px
    }
}

.color_page .block-type-links-heading {
    margin: 16px 0 80px
}

@media screen and (min-width:1024px) {
    .color_page .block-type-links-heading {
        margin-top: 40px
    }
}

@media screen and (min-width:1280px) {
    .product_page .block {
        padding-right: 0
    }

    .product_page .block_inner {
        padding-left: 0;
        max-width: 1600px
    }
}

.product_page:not(.cream)>header {
    border-right-width: 0
}

.product_page main.bg-solid-cream {
    border-left: 1px solid rgba(0, 0, 0, .2)
}

@media screen and (min-width:1280px) {
    .product_page_top {
        display: flex
    }

    .product_page_top .product_page_content {
        width: 60%
    }
}

.product_page_heading {
    display: flex;
    flex-direction: column-reverse;
    justify-content: flex-end;
    width: 100%
}

@media screen and (min-width:1280px) {
    .product_page_heading {
        width: 40%
    }
}

.product_page_heading h1 {
    margin-top: 32px
}

@media screen and (min-width:1024px) {
    .product_page_heading h1 {
        margin-top: 64px
    }
}

.product_page_heading .h5,
.product_page_heading blockquote cite,
blockquote .product_page_heading cite {
    margin-top: 0
}

.product_page_heading span,
.product_page_intro span,
.product_page_row_content span {
    font-family: Roboto Condensed, monospace;
    font-variation-settings: "wght" 300;
    font-weight: 300;
    font-size: 16px;
    line-height: 1;
    letter-spacing: .03em;
    position: relative
}

.product_page_heading span {
    top: -4.8vw
}

@media screen and (min-width:1024px) {
    .product_page_heading span {
        top: -56px
    }
}

.product_page_intro span {
    top: -1.5vw
}

@media screen and (min-width:1024px) {
    .product_page_intro span {
        top: -24px
    }
}

.product_page_intro,
.product_page_row_content {
    margin-top: 24px
}

@media screen and (min-width:1280px) {

    .product_page_intro,
    .product_page_row_content {
        margin-top: 0;
        flex-shrink: 0
    }
}

.product_page_content {
    display: flex;
    flex-direction: column
}

.product_page_row {
    margin-top: 64px
}

@media screen and (min-width:1024px) {
    .product_page_row {
        margin-top: 80px
    }
}

@media screen and (min-width:1280px) {
    .product_page_row {
        display: flex;
        width: 100%
    }
}

.product_page_row_heading {
    width: 100%;
    margin-bottom: 24px
}

.product_page .block-type-links-heading {
    margin: 16px 0 80px
}

@media screen and (min-width:1024px) {
    .product_page .block-type-links-heading {
        margin-top: 40px
    }
}

.product_page_features>*+* {
    margin-top: 40px
}

@media screen and (min-width:1024px) {
    .product_page_features>*+* {
        margin-top: 64px
    }
}

.product_page_content__header,
.product_page_features .workshop blockquote+p,
.product_page_features h4+p,
.workshop .product_page_features blockquote+p {
    margin-top: 24px
}

@media screen and (min-width:1280px) {
    .product_page_content__header {
        margin-top: 0
    }
}

.product_page :is(h1, h2, h3) {
    text-wrap: balance
}

.product_page :is(.product_page_content__header, .product_page_features, .product_page_image, .product_page_intro, .basic-card)+* {
    margin-top: 64px
}

@media screen and (min-width:1024px) {
    .product_page :is(.product_page_content__header, .product_page_features, .product_page_image, .product_page_intro, .basic-card)+* {
        margin-top: 80px
    }
}

.product_page_content__header>*+* {
    margin-top: 40px
}

@media screen and (min-width:1024px) {
    .product_page_content__header>*+* {
        margin-top: 64px
    }
}

.product_page_content__header>.h5+*,
blockquote .product_page_content__header>cite+* {
    margin-top: 24px
}

.product_page_page_content.flow {
    --flow-space: 80px
}

.product_button {
    display: flex
}

@media screen and (min-width:1280px) {
    .product_page_heading {
        padding-left: 80px
    }
}

@media screen and (min-width:1600px) {
    .product_page_heading {
        padding-left: 120px
    }
}

@media screen and (min-width:1280px) {
    .product_page_content {
        padding-right: 72px
    }
}

@media screen and (min-width:768px) {
    .product_page_blocks {
        padding: 0 0 0 72px
    }
}

.product_page_block {
    padding: 80px 24px
}

@media screen and (min-width:480px) {
    .product_page_block {
        padding: 80px 40px
    }
}

@media screen and (min-width:768px) {
    .product_page_block {
        padding: 120px 64px 120px 72px
    }
}

@media screen and (min-width:1024px) {
    .product_page_block {
        padding: 120px 72px
    }
}

@media screen and (min-width:1280px) {
    .product_page_block {
        padding-right: 80px;
        padding-left: 80px
    }
}

@media screen and (min-width:1600px) {
    .product_page_block {
        padding-left: 120px
    }
}

@media screen and (min-width:1280px) and (min-height:720px) {
    .product_page_block {
        padding-top: 160px;
        padding-bottom: 160px
    }
}

.product_page_block.bg-solid-cream {
    border-top: 1px solid rgba(0, 0, 0, .2)
}

.product main>.block:first-child {
    padding-bottom: 80px
}

@media screen and (min-width:480px) {
    .product main>.block:first-child {
        padding-bottom: 80px
    }
}

@media screen and (min-width:768px) {
    .product main>.block:first-child {
        padding-bottom: 120px
    }
}

@media screen and (min-width:1024px) {
    .product main>.block:first-child {
        padding-bottom: 120px
    }
}

@media screen and (min-width:1280px) and (min-height:720px) {
    .product main>.block:first-child {
        padding-bottom: 160px
    }
}

.team_page_content_intro {
    margin-bottom: 64px
}

@media screen and (min-width:768px) {
    .team_page_content_intro {
        margin-bottom: 80px;
        max-width: 680px
    }
}

@media screen and (min-width:1024px) {
    .team_page_content_intro {
        margin-bottom: 120px
    }
}

@media screen and (min-width:1024px) {
    .team_page_content_principle {
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-gap: 80px;
        align-items: center;
        margin-bottom: 80px
    }
}

.team_page_content_principle img {
    margin-bottom: 40px
}

@media screen and (min-width:1024px) {
    .team_page_content_principle img {
        margin-bottom: 0
    }
}

@media screen and (min-width:1024px) {
    .team_page_content_team {
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-gap: 80px;
        align-items: start
    }
}

.team_page_content_team_member {
    margin-bottom: 40px
}

@media screen and (min-width:1024px) {
    .team_page_content_team_member {
        margin-bottom: 0
    }
}

.team_page_content_team_member h6 {
    margin: 24px 0 40px
}

.team_page_content_network {
    margin-top: 80px
}

@media screen and (min-width:1024px) {
    .team_page_content_network {
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-gap: 80px;
        align-items: start
    }
}

@media screen and (min-width:1024px) {
    .team_page_content_network .h1 {
        font-size: 160px;
        line-height: 160px
    }
}

.team_page_content_network .h6 {
    margin: 64px 0 24px
}

.team_page_content_testimonial {
    margin-top: 80px
}

@media screen and (min-width:1024px) {
    .team_page_content_testimonial {
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-gap: 80px;
        align-items: center
    }
}

.team_page_content_testimonial blockquote {
    margin: 0
}

.card {
    position: relative;
    border-right: 1px solid rgba(0, 0, 0, .2);
    padding: 40px 24px
}

@media screen and (min-width:480px) {
    .card {
        padding: 48px 40px
    }
}

@media screen and (min-width:1024px) {
    .card {
        padding: 64px 40px
    }
}

@media screen and (min-width:1280px) {
    .card {
        padding: 80px 40px
    }
}

.cards--alt .card {
    border-right-color: #fff
}

.cards--alt .card .card_header:after,
.cards--alt .card .card_header:before {
    background: #fff
}

.card_header {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    transform: translateY(-50%);
    display: flex;
    align-items: center
}

.card_header:after,
.card_header:before {
    content: "";
    top: 0;
    height: 1px;
    background: rgba(0, 0, 0, .2);
    display: block
}

.card_header:before {
    width: 16px;
    flex-shrink: 0
}

.card_header:after {
    width: 100%
}

.card_header span {
    padding: 0 24px;
    flex-shrink: 0
}

.card.\--full {
    border-left: 1px solid rgba(0, 0, 0, .2);
    border-bottom: 1px solid rgba(0, 0, 0, .2)
}

@media screen and (min-width:1024px) {
    .card.\--full .card_header:before {
        width: 48px
    }
}

@media screen and (min-width:1024px) {
    .card.\--full .card_number {
        padding: 0 16px
    }
}

@media screen and (min-width:1024px) {
    .card.\--full {
        padding: 64px
    }
}

@media screen and (min-width:1024px) {
    .process_inner {
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-gap: 80px
    }
}

.process_heading {
    margin-bottom: 80px
}

@media screen and (min-width:1024px) {
    .process_heading {
        margin-bottom: 0
    }
}

.process_heading .process_title {
    margin-top: 80px
}

@media screen and (min-width:1024px) {
    .process_heading .process_title {
        position: sticky;
        top: 80px
    }
}

.process_badge {
    margin: 40px 0
}

@media screen and (min-width:1024px) {
    .process_badge {
        margin: 0;
        display: flex;
        flex-direction: column
    }
}

.process_line {
    width: 1px;
    background-color: currentColor;
    height: 80px;
    margin: 80px 60px
}

@media screen and (min-width:1024px) {
    .process_content {
        padding-top: 200px
    }
}

.process .num {
    display: flex;
    margin-bottom: 16px
}

.process_step_heading {
    margin-bottom: 40px
}

.process_footer {
    padding-top: 40px
}

@media screen and (min-width:1024px) {
    .process_footer {
        display: grid;
        grid-template-columns: 1fr 1fr;
        align-items: center;
        grid-gap: 120px 80px;
        padding-top: 80px
    }
}

.process_footer img {
    width: 100%
}

.process_cta .process_title {
    margin: 24px 0 48px
}

html:not(.splash_seen) body.home {
    transform: translateY(100vh);
    -webkit-animation: slideInMain;
    animation: slideInMain;
    -webkit-animation-duration: 1.2s;
    animation-duration: 1.2s;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
    -webkit-animation-delay: 3.6s;
    animation-delay: 3.6s
}

body.home .trigger.splash {
    -webkit-animation: slideOutSplash;
    animation: slideOutSplash;
    -webkit-animation-duration: 1.2s;
    animation-duration: 1.2s;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
    -webkit-animation-delay: 3.6s;
    animation-delay: 3.6s
}

body.home .trigger.splash .splash__inner {
    display: block;
    -webkit-animation: fadeInSplash;
    animation: fadeInSplash;
    -webkit-animation-duration: 1.2s;
    animation-duration: 1.2s;
    -webkit-animation-timing-function: ease;
    animation-timing-function: ease;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
    -webkit-animation-delay: 0;
    animation-delay: 0
}

body.home .trigger.splash .splash__logo,
body.home .trigger.splash .splash__strap {
    -webkit-animation: fadeIn;
    animation: fadeIn;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both
}

body.home .trigger.splash .splash__logo {
    -webkit-animation-duration: 1.2s;
    animation-duration: 1.2s;
    -webkit-animation-delay: .3s;
    animation-delay: .3s;
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in
}

body.home .trigger.splash .splash__strap {
    -webkit-animation-duration: 1.8s;
    animation-duration: 1.8s;
    -webkit-animation-delay: 1.2s;
    animation-delay: 1.2s;
    -webkit-animation-timing-function: ease;
    animation-timing-function: ease
}

.splash {
    position: fixed;
    z-index: 50;
    height: 100%;
    width: 100%;
    background: #F5F3FF;
    transform: translateY(-100vh)
}

.splash__inner {
    height: 100%;
    width: 100%;
    display: none
}

.splash__content {
    height: 100%;
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    padding: 0 40px
}

@media screen and (min-width:480px) {
    .splash__content {
        padding: 0 40px
    }
}

@media screen and (min-width:768px) {
    .splash__content {
        padding: 0 144px
    }
}

@media screen and (min-width:1280px) {
    .splash__content {
        padding: 0 152px
    }
}

.splash__bg {
    background: linear-gradient(180deg, #F5F3FF 50%, #2F1F65);
    height: 100%;
    width: 100%;
    position: absolute;
    top: 0;
    z-index: -1
}

.splash__logo,
.splash__strap {
    display: block;
    position: relative
}

.splash__strap {
    font-size: 16px;
    letter-spacing: .24em;
    padding-bottom: 20px;
    position: relative;
    left: 1px
}

@media screen and (min-width:768px) {
    .splash__strap {
        font-size: 17px;
        letter-spacing: .3em
    }
}

@media screen and (min-width:1024px) {
    .splash__strap {
        letter-spacing: .5em
    }
}

.splash__logo {
    font-family: Eksell Display, serif;
    font-variation-settings: "wght" 80;
    font-size: 56px;
    line-height: 1;
    margin-bottom: 16px
}

@media screen and (min-width:768px) {
    .splash__logo {
        font-size: 64px
    }
}

@media screen and (min-width:1024px) {
    .splash__logo {
        font-size: 80px
    }
}

@media screen and (min-width:1024px) {
    .splash .spacer {
        width: 100%
    }
}

.splash .link {
    position: absolute;
    bottom: 40px;
    left: 40px
}

@media screen and (min-width:1024px) {
    .splash .link {
        position: static;
        margin-top: 0;
        display: flex;
        justify-content: flex-end
    }
}

.splash p {
    flex-shrink: 0
}

@media screen and (min-width:1024px) {
    .splash p {
        margin-top: 4px
    }
}

.splash.hide {
    display: none
}

.social_share__inner {
    display: flex;
    border: 1px solid #00020f;
    padding: 8px 16px;
    align-items: center;
    justify-content: space-between;
    margin-top: 80px;
    max-width: 170px
}

@media screen and (min-width:1024px) {
    .social_share__inner {
        flex-direction: column;
        padding: 16px 8px;
        position: sticky;
        top: 64px;
        margin-top: 0
    }
}

.social_share__inner a {
    padding: 0;
    display: flex;
    height: 24px;
    width: 40px;
    align-items: flex-end;
    justify-content: center
}

@media screen and (min-width:1024px) {
    .social_share__inner a {
        height: 40px;
        width: 24px;
        align-items: center;
        justify-content: flex-end
    }
}

@media screen and (min-width:1024px) {
    .social_share__inner a img {
        transform: rotate(90deg);
        transform-origin: 50% 50%
    }
}

.social_share__inner a img[alt=email] {
    position: relative;
    left: -2px
}

.block-type-banner {
    position: relative
}

.block-type-banner .block_inner {
    max-width: none
}

@media screen and (min-width:1024px) {
    .block-type-banner {
        padding-top: 80px;
        padding-bottom: 80px;
        margin-bottom: 80px
    }
}

@media screen and (min-width:1280px) {
    .block-type-banner {
        padding-top: 96px
    }
}

@media screen and (min-width:1440px) {
    .block-type-banner {
        padding-top: 120px
    }
}

@media screen and (min-height:800px) {
    .block-type-banner {
        padding-top: 120px
    }
}

@media screen and (min-height:900px) {
    .block-type-banner {
        padding-top: 160px
    }
}

.block-type-banner-subheading {
    max-width: 640px
}

@media screen and (min-width:1160px) {
    .block-type-banner-subheading {
        max-width: 740px
    }
}

.block-type-banner-text {
    margin-top: 32px
}

@media screen and (min-width:1024px) {
    .block-type-banner-text {
        max-width: 1020px;
        margin-top: 64px;
        align-items: center
    }
}

.block-type-banner .badge {
    margin-top: 48px
}

@media screen and (min-width:1024px) {
    .block-type-banner .badge {
        margin-top: 0;
        margin-left: 72px
    }
}

.block-type-banner-bar {
    display: none
}

@media screen and (min-width:1024px) {
    .block-type-banner-bar {
        display: block;
        margin-top: 60px
    }

    .block-type-banner-bar-line {
        height: 96px;
        margin-left: 64px;
        width: 1px;
        background: #00020f
    }
}

.badge {
    height: 120px;
    width: 120px;
    position: relative
}

.badge__arrow,
.badge__bg {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center
}

.badge__bg img {
    -webkit-animation: spin 25s linear infinite forwards;
    animation: spin 25s linear infinite forwards
}

.block-type-header {
    padding-bottom: 0 !important
}

.block-type-header_inner {
    display: flex;
    flex-direction: column-reverse;
    min-height: calc(100vh - 72px);
    justify-content: center
}

@media screen and (min-width:768px) {
    .block-type-header_inner {
        min-height: 100vh
    }
}

.block-type-header_inner--alt {
    min-height: unset;
    padding-bottom: 64px
}

@media screen and (min-width:768px) {
    .block-type-header_inner--alt {
        padding-bottom: 80px
    }
}

@media screen and (min-width:1024px) {
    .block-type-header_inner--alt {
        padding-bottom: 120px
    }
}

.block-type-header h2 {
    margin: 0 0 40px
}

@media screen and (min-width:1024px) {
    .block-type-header h2 {
        margin: 46px 0 39px
    }

    .block-type-header h2.lead {
        /* max-width: 548px */
    }
}

.block-type-header .arrow {
    position: relative;
    width: 1px;
    margin: 40px 0 0 8px;
    height: 64px
}

@media screen and (min-width:1024px) {
    .block-type-header .arrow {
        margin-top: calc(64px - .15em);
        margin-left: 0
    }
}

.block-type-header .arrow:before {
    content: "";
    width: 1px;
    height: 64px;
    background: currentColor;
    display: block;
    flex-shrink: 0;
    position: absolute;
    top: 0;
    left: 10px
}

.block-type-header .arrow:after {
    content: "";
    display: block;
    position: absolute;
    left: 4px;
    top: 64px;
    border-color: transparent transparent currentcolor currentcolor;
    border-style: solid;
    border-width: 1px;
    transform: rotate(-45deg);
    width: 11px;
    height: 11px;
    margin-top: -15px
}

@media screen and (min-width:1280px) {
    .block-type-cards-row {
        display: grid;
        grid-template-columns: 1fr 1fr;
        align-items: flex-end;
        grid-gap: 80px
    }

    .block-type-cards-row .flag__content p,
    .block-type-cards-row .lead,
    .flag__content .block-type-cards-row p {
        margin-bottom: 6px
    }
}

.block-type-cards-heading {
    margin-bottom: 24px
}

@media screen and (min-width:1280px) {
    .block-type-cards-heading {
        margin-bottom: 0
    }
}

.block-type-cards-heading .h1 {
    margin-top: 24px
}

.block-type-cards .flag__content p,
.block-type-cards .lead,
.flag__content .block-type-cards p {
    margin-top: 48px
}

@media screen and (min-width:1024px) {

    .block-type-cards .flag__content p,
    .block-type-cards .lead,
    .flag__content .block-type-cards p {
        margin-top: 0
    }
}

.block-type-cards-button {
    margin-top: 64px
}

@media screen and (min-width:768px) {
    .block-type-cards-button {
        margin-top: 80px
    }
}

.cards {
    border-bottom: 1px solid rgba(0, 0, 0, .2);
    border-left: 1px solid rgba(0, 0, 0, .2);
    margin-top: 64px
}

@media screen and (min-width:480px) {
    .cards {
        margin-top: 80px
    }
}

@media screen and (min-width:1024px) {
    .cards {
        margin-top: 120px;
        display: grid;
        grid-template-columns: 1fr 1fr
    }
}

.cards--alt {
    border-bottom: 1px solid #fff;
    border-left: 1px solid #fff
}

@media screen and (min-width:1024px) {
    .cards--alt {
        margin-top: 80px
    }
}

.cards ul {
    margin-top: 40px
}

.block-type-cta {
    padding-top: 48px;
    padding-bottom: 48px
}

@media screen and (min-width:768px) {
    .block-type-cta {
        padding-top: 64px;
        padding-bottom: 64px
    }
}

@media screen and (min-width:1024px) {
    .block-type-cta .block_inner {
        justify-content: space-between
    }

    .block-type-cta .block_inner>div {
        width: calc(50% - 40px);
        display: flex;
        align-items: center
    }

    .block-type-cta .block_inner>div p {
        font-size: 16px
    }
}

.block-type-cta p {
    margin-bottom: 48px
}

@media screen and (min-width:1024px) {
    .block-type-cta p {
        margin-bottom: 0
    }
}

.newsletter {
    display: flex;
    border: 1px solid #00020f
}

.newsletter button {
    -webkit-appearance: none;
    background: transparent;
    border: none;
    position: relative;
    width: 137px;
    flex-shrink: 0;
    padding: 13px 24px 13px 8px;
    display: flex;
    flex-direction: row-reverse;
    align-items: baseline;
    color: #00020f
}

@media screen and (min-width:768px) {
    .newsletter button {
        padding: 20px 24px 20px 8px
    }
}

.newsletter button:before {
    content: "";
    height: 1px;
    background: currentColor;
    display: block;
    width: 64px;
    flex-shrink: 1;
    position: relative;
    top: -4px
}

@media screen and (min-width:768px) {
    .newsletter button:before {
        width: 80px
    }
}

.newsletter button:after {
    content: "";
    display: block;
    position: absolute;
    right: 26px;
    top: 50%;
    border-color: transparent currentcolor currentcolor transparent;
    border-style: solid;
    border-width: 1px;
    transform: rotate(-45deg);
    width: 11px;
    height: 11px;
    margin-top: -6px
}

.newsletter button span {
    opacity: 0;
    padding: 0 4px 0 0;
    transform: translateX(0);
    transition: opacity .15s ease-out, transform .15s ease-out;
    position: relative;
    top: 1px;
    background: #fee639
}

.newsletter input {
    -webkit-appearance: none;
    background: transparent;
    border: none;
    padding: 13px 24px;
    width: 100%;
    font-size: 16px;
    line-height: 22px
}

@media screen and (min-width:768px) {
    .newsletter input {
        font-size: 18px;
        padding: 20px 24px
    }
}

.newsletter input:focus {
    outline: none
}

.newsletter input:focus+button span {
    opacity: 1;
    margin-right: 8px;
    transform: translateX(28px)
}

::-webkit-input-placeholder {
    color: #00020f
}

::-moz-placeholder {
    color: #00020f
}

:-ms-input-placeholder {
    color: #00020f
}

:-moz-placeholder {
    color: #00020f
}

.block-type-calltoaction .block_inner {
    max-width: none
}

.block-type-calltoaction .block_inner p {
    max-width: 70ch;
    text-wrap: balance
}

.block-type-calltoaction .block_inner img {
    max-width: 100%
}

.block-type-calltoaction .block_inner>*+* {
    -webkit-margin-before: 40px;
    margin-block-start: 40px
}

.block-type-calltoaction .block_inner>*+img {
    margin-top: 64px
}

@media screen and (min-width:768px) {
    .block-type-calltoaction .block_inner>*+img {
        margin-top: 80px
    }
}

.block-type-calltoaction .block_inner>*+.cta_button {
    margin-top: 64px
}

@media screen and (min-width:768px) {
    .block-type-calltoaction .block_inner>*+.cta_button {
        margin-top: 80px
    }
}

.cta_button {
    display: flex
}

.block-type-work-video {
    margin-bottom: 64px
}

@media screen and (min-width:1024px) {
    .block-type-work-video {
        margin-bottom: 80px
    }
}

.block-type-work .work_archive {
    padding-bottom: 64px
}

@media screen and (min-width:1024px) {
    .block-type-work .work_archive {
        padding-bottom: 80px
    }
}

.block-type-work .work_archive:empty {
    padding-bottom: 0
}

@media screen and (min-width:480px) {
    .block-type-work .work_button {
        display: flex
    }
}

@media screen and (min-width:480px) {
    .block-type-work .work_card:nth-child(3) {
        display: none
    }
}

@media screen and (min-width:1024px) {
    .block-type-work .work_card:nth-child(3) {
        display: block
    }
}

.flag {
    padding-bottom: 64px
}

@media screen and (min-width:1024px) {
    .flag {
        padding-bottom: 80px;
        padding-bottom: 160px;
        display: flex;
        align-items: flex-start
    }
}

.flag__number {
    position: relative;
    padding-bottom: 40px
}

@media screen and (min-width:1024px) {
    .flag__number {
        padding-right: 40px;
        padding-bottom: 0;
        width: 50%;
        position: sticky;
        top: 80px
    }

    .flag__number span {
        left: -2%
    }
}

@media screen and (min-width:1280px) {
    .flag__number {
        top: 120px
    }
}

@media screen and (min-width:1440px) and (min-height:800px) {
    .flag__number {
        top: 160px
    }
}

.flag__number svg {
    max-width: 100%
}

.flag__number__outer {
    display: none
}

@media screen and (min-width:768px) {
    .flag__number__outer {
        display: flex;
        flex-direction: column;
        justify-content: center;
        height: 100%
    }
}

.flag__number__inner {
    display: flex;
    flex-direction: column;
    justify-content: center
}

@media screen and (min-width:768px) {
    .flag__number__inner {
        position: absolute;
        top: -8px;
        left: 0;
        height: 100%
    }
}

@media screen and (min-width:1024px) {
    .flag__number__inner {
        width: -webkit-fit-content;
        width: -moz-fit-content;
        width: fit-content
    }
}

.flag__number__inner .h1 {
    margin-top: 8px
}

@media screen and (min-width:1024px) {
    .flag__number__inner .h1 {
        font-size: clamp(56px, 7.5vw, 104px);
        line-height: clamp(56px, 7.5vw, 104px)
    }
}

.flag__number__inner .h1 br {
    display: none
}

@media screen and (min-width:768px) {
    .flag__number__inner .h1 br {
        display: block
    }
}

.flag__number__inner p {
    display: flex;
    align-items: center
}

.flag__number__inner p.num {
    margin-bottom: 16px
}

@media screen and (min-width:1024px) {
    .flag__content {
        width: 50%;
        margin-top: 80px;
        padding-left: 40px
    }
}

.flag__content .card {
    margin-top: 80px
}

.flag__content__images {
    margin-top: 64px
}

@media screen and (min-width:1024px) {
    .flag__content__images {
        margin-top: 80px
    }
}

.flag__content__images img {
    width: 100%
}

.flag__content__images img+img {
    margin-top: 64px
}

.flag__content ul {
    margin: 0
}

.flags+.block_button {
    padding-top: 0
}

.links {
    margin-top: 40px
}

@media screen and (min-width:1024px) {
    .links {
        display: grid;
        grid-gap: 40px;
        grid-template-columns: repeat(3, 1fr);
        margin-top: 80px
    }
}

.links .link {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 40px;
    margin-bottom: 40px;
    border: 1px solid;
    text-decoration: none
}

@media screen and (min-width:1024px) {
    .links .link {
        margin: 0
    }
}

.links .link__inner {
    height: 100%
}

.links .link__link {
    opacity: 0;
    transform: translateY(24px);
    margin: 24px 0;
    transition: transform .15s ease-out 0s
}

.links .link p {
    margin-top: 24px
}

.links .link .tag {
    margin: 0
}

.workshop__heading {
    margin-bottom: 24px
}

.workshop__headline *+* {
    margin-top: 16px
}

@media screen and (min-width:540px) {
    .workshop__headline *+* {
        margin-top: 0
    }
}

@media screen and (min-width:540px) {
    .workshop__headline {
        display: flex;
        align-items: center;
        width: 100%
    }

    .workshop__headline__arrow {
        position: relative;
        width: calc(100% - 32px);
        margin: 0 32px;
        text-align: center;
        height: 1px
    }

    .workshop__headline__arrow:before {
        content: "";
        height: 1px;
        background: currentColor;
        display: block;
        width: 100%;
        flex-shrink: 0;
        position: absolute;
        top: 0;
        left: 0
    }

    .workshop__headline__arrow:after {
        content: "";
        display: block;
        position: absolute;
        right: 2px;
        top: 0;
        border-color: transparent currentcolor currentcolor transparent;
        border-style: solid;
        border-width: 1px;
        transform: rotate(-45deg);
        width: 11px;
        height: 11px;
        margin-top: -6px
    }
}

.workshop__content {
    margin-top: 64px
}

@media screen and (min-width:480px) {
    .workshop__content {
        margin-top: 80px
    }
}

@media screen and (min-width:1024px) {
    .workshop__content {
        margin-top: 120px
    }
}

.workshop__content>*+* {
    margin-top: 32px
}

@media screen and (min-width:1024px) {
    .workshop__content>*+* {
        margin-top: 0
    }
}

@media screen and (min-width:1024px) {
    .workshop__content {
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-gap: 80px
    }
}

@media screen and (min-width:1024px) {
    .workshop__quote {
        display: flex;
        align-items: center
    }
}

.workshop blockquote {
    margin-left: 0;
    margin-right: 0
}

.workshop img {
    width: 100%
}

@media screen and (min-width:1024px) {
    .workshop img {
        margin-top: 0
    }
}

.promo>div+div:not(.promo_button) {
    margin-top: 64px
}

@media screen and (min-width:480px) {
    .promo>div+div:not(.promo_button) {
        margin-top: 80px
    }
}

@media screen and (min-width:1024px) {
    .promo>div+div:not(.promo_button) {
        margin-top: 120px
    }
}

@media screen and (min-width:1024px) {
    .promo_header {
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-gap: 80px;
        align-items: flex-end
    }
}

.promo_header .h1 {
    margin-bottom: 24px
}

@media screen and (min-width:1024px) {
    .promo_header .h1 {
        margin-bottom: 0
    }
}

.flag__content .promo_header p,
.promo_header .flag__content p,
.promo_header .lead {
    margin-top: 48px
}

@media screen and (min-width:1024px) {

    .flag__content .promo_header p,
    .promo_header .flag__content p,
    .promo_header .lead {
        position: relative;
        top: -5px;
        margin-top: 0
    }
}

@media screen and (min-width:1440px) {

    .flag__content .promo_header p,
    .promo_header .flag__content p,
    .promo_header .lead {
        top: -10px
    }
}

.promo_button {
    margin-top: 64px
}

@media screen and (min-width:480px) {
    .promo_button {
        display: flex
    }
}

@media screen and (min-width:768px) {
    .promo_button {
        margin-top: 80px
    }
}

.promo .card_grid>div+div {
    margin-top: 64px
}

@media screen and (min-width:1024px) {
    .promo .card_grid>div+div {
        margin-top: 0
    }
}

@media screen and (min-width:1024px) {
    .promo .card_grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-row-gap: 48px;
        grid-column-gap: 72px
    }
}

.promo .card_grid .dash {
    position: relative;
    top: 1px
}